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Field of the Invention 



The present invention relates generally to managing resources in a 
telecommunications network or computer system environment. 

Related Art 

Telecommunications network products are services provided by telephone 
companies that are carried on telecommunications networks. A widely known 
example is dial-1 long distance voice service which allows a customer to dial a 1 
plus a ten digit number from his or her home telephone, talk to a party who 
answers the telephone on the line of the ten digit number dialed, and pay for the 
telephone call when billed at the end of the month. 

Although dial-1 is popular, other calling and payment options, also referred 
to as enhanced services, are sometimes preferable. For example, debit calling 
allows an individual to make a call from a phone other than their home phone and 
charge the call to the debit account. With debit calling, also referred to as prepaid 
calling, a customer puts funds in an account and has those fiinds debited each time 
a telephone call is made. Another calling and payment option is collect calling in 
which the call is billed to the receiving party's account. 

Enhanced services are not limited to other calling and payment options. 
Enhanced services can provide a customer with information such as access to 
news and weather. Another enhanced service is 1-800-MUSICNOW which gives 
a telephone caller the ability to select and listen to music and then order a 
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recording of the music by entering selections in response to menu prompts using 
the keypad of the telephone. 

Enhanced services are possible because intelligent services networks 
(ISNs) within telephone companies telecommunications networks have advanced 
capabilities needed to process the enhanced service calls. The ISNs are networks 
that comprise ISN components capable of performing enhanced service call 
processing functions. Exemplary ISN components include computer systems that 
store data and perform protocol conversion and exchanges, also referred to as 
switches that route calls. In addition, for processing enhanced service calls, 
information about customers, calls, and teleconmiunications services is needed. 

The information and ISN components are resources. Within a 
telecommunications network, resources are sources of assistance in performing 
functions needed to process calls. 

For example, information such as the destination number dialed by a caller 
provides assistance in call processing by providing the area code which can be 
translated to determine what telecommunications network circuits should be used 
by ISN components to route the call to the intended recipient. 

Information about resources may be obtained in multiple ways. For 
example, reports may be available that provide printed information about the 
resources. In addition, information may be available on-line by a human operator 
entering commands. Also, alarms may be generated that alert a human system 
overseer that a particular resource or group of resources is unavailable, 
malfunctioning, and/or in use more often than recommended. In typical ISNs, 
information is stored in an automated call distributor (ACD), an intelligent service 
network application processor (ISNAP), and other ISN components. The ACD 
provides the call switching, queuing, and protocol conversion functions. The 
intelligent service network applications processor (ISNAP) provides group 
selection functionality for the ISN. 

Information about the resources is typically stored in electronic format in 
one or more computer systems. Application programmer interfaces (APIs) may 
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be used to communicate call processing information and information about 
telecommunications components within a computer program. The APIs are 
procedures for communication within a computer program that reside in main 
memory and are processed by a processor. The APIs are used by programmable 
switches, such as the Excel programmable switch, to perform call processing 
fimctions. The API used by the Excel programmable switch is described in a 
document entitled, "Excel API specification revision 5.0." Additional APIs 
include the Tabman, Queman, Sysmem, and Shmman APIs that are described in 
more detail below. 

Typically, information about resources is handled in a non-standard, de- 
centralized manner. Information about various components within a 
telecommunications network is accessible via the particular component. For 
example, central processing unit (CPU) availability of a switch is obtained from 
the switch. Information about the processing capability of computer systems that 
assist the switch is stored in memory of the computer systems. In addition, 
information is only accessible using commands or APIs that can be understood by 
the component storing the information. For example, to access information about 
the switch, commands that can be understood by the switch must be used to obtain 
the data about the switch that is stored within the switch. To access information 
about a computer system assisting the switch, commands understood by the 
assisting computer system must be used. 

Summary of the Invention 

The present invention is a system and method for managing resources, 
more particularly ISN resources. Resource management is performed by a 
resource management routine within an application program that resides in the 
memory of a switch controller. The resource management routine manages 
intemal switch controller resources and extemal resources such as programmable 
switches. 
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An ISN includes components which perform enhanced call handling 
functions, such as operator consoles and automated response units, and 
components that provide access to databases and other networks. Enhanced 
services, such as pre-paid service, calling card, operator service, 1-800- 
COLLECT, and 1-800-MUSIC-NOW are possible using the ISN. A switch 
controller is a telecommunications network component which controls the 
operation of one or more programmable switches and is capable of performing 
complex call processing to handle service specific features of enhanced 
telecommunications services. The switch controller provides an interface between 
the public switching telephone network (PSTN) and the intelligent service 
network (ISN). 

The present invention is a system-wide approach to resource management. 
The resource management routine provides standard procedures used by processes 
to obtain information about resources. In addition, the resource management 
routine provides controlled access to information about resources. The resource 
management routine is essentially a protective layer for information about 
resources. Compared to a library housing books which are resources for people 
to gain information, the resource management routine is a librarian which controls 
in a standardized way how resources are accessed by various different processes. 

The resource management routine comprises electronic libraries residing 
in memory of the switch controller that store information about resources and 
resource management application programmer interfaces (APIs) that are used to 
access the stored information. Resource management APIs are stored in the main 
memory and processed by the processor of a computer. In order to process the 
resource management API, the processor calls the resource management API 
procedure from main memory. The resource management API procedure 
executes commands using input data. Completion of the execution of the resource 
management API results in return data which is the data requested and/or data 
indicating whether the transaction was successful and an output which is an action 
requested by the initiating routine. 
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Resource management APIs are generic in that they are not affected by 
changes to other APIs or messaging techniques, such as APIs for internal switch 
controller processing, the Excel programmable switch APIs, or changes to ISN 
protocols. Having a generic resource management API provides various benefits, 
including flexibility and extensibility. Flexibility is possible because the resource 
management APIs are independent of the other messaging techniques. Therefore, 
resource management does not need to be upgraded with changes to other 
routines and computer systems. In addition, if a new resource is added, the 
resource management routine needs to be updated but the new resource has a 
minimal impact on other routines and computer systems. As a result, changes can 
be more readily made to the ISN. 

In addition, extensibility is improved with generic resource management 
APIs because new services can be more easily implemented. New services can be 
more easily implemented because modifications are not needed to the resource 
management routine unless implementation of the new service involves adding a 
new resource or modifying a resource such that access to data about that resource 
is affected. If a new resource is added or an existing resource is modified, changes 
are needed to the APIs associated with that resource and are not needed system 
wide. 

Furthermore, maintenance and debugging of resource management 
routines within the switch controller are simplified and more accurate. 
Maintenance and debugging are simplified and more accurate because resource 
management APIs are standardized for the various resources. In other words, 
resource management APIs follow similar procedures when possible although the 
information is being accessed about different resources. As a result, resolution of 
maintenance and debugging issues for one resource management API is applicable 
to other resource management APIs. Also, resource management APIs are 
grouped within the same resource management routine. Therefore, maintenance 
and debugging resource management code involves accessing one routine and not 
attempting to identify resource management fiinctionality within various processes 
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and routines. Furthermore, individual routines are not required to have unique 
procedures and code for accessing information about resources. In addition to 
providing standard procedures, the generic resource management routine, which 
is available to routines requiring information about resources, reduces the overall 
code required to access resources. 

Further features and advantages of the invention, as well as the structure 
and operation of various embodiments of the invention, are described in detail 
below with reference to the accompanying drawings. 

Brief Description of the Figures and Tables 

The present invention is described with reference to the accompanying 
drawings wherein: 

Fig. 1 is a block diagram of an exemplary embodiment of a resource 
management environment according to one embodiment of the present invention; 

Fig. 2 is a block diagram of the hardware configuration of a switch 
controller according to one embodiment of the present invention; 

Fig. 3 is a flowchart of a resource management environment according to 
one embodiment of the present invention; 

Fig. 4 is a block diagram of a resource management interface according to 
one embodiment of the present invention; 

Fig. 5 illustrates the operation of a resource management process flow 
according to one embodiment of the present invention; 

Fig. 6 is a diagram of an exemplary embodiment of resource management 
according to one embodiment of the present invention; and 

Tables 1-69 illustrate application programmer interfaces and data 
structures according to one embodiment of the present invention. 

In the drawings like reference numbers generally indicate identical 
functionally similar and/or structurally similar components. The drawing in which 
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an element first appears is indicated by the left most digits in the corresponding 
reference number. 

Detailed Description of the Preferred Embodiments 
1.0 Overview 

Resource management within a switch controller provides management of 
intelligent service network (ISN) resources. A resource management routine 
within an application program residing in the memory of the switch controller 
manages resources by providing a protective layer of standard procedures, 
referred to as resource management application programmer interfaces (APIs) that 
are used to access information about ISN resources. The information about the 
ISN resources is stored electronically in memory and is organized in table format. 
The electronically stored data is referred to as the resource manager tables. 

The ISN resources are resources associated with an ISN. An ISN is a 
network of components that perform functions to provide enhanced services, such 
as pre-paid service, calling card, operator service, 1-800-COLLECT, and 
1-800-MUSIC-NOW. The ISN resources are sources of assistance in performing 
functions to provide enhanced services. The ISN components, such as operator 
consoles and automated response units, provide capabilities needed to process 
enhanced service calls and are ISN resources. In addition, information related to 



The resource management routine resides within the memory of a switch 
controller. A switch controller is a telecommunications network component which 
provides an interface between the public switching telephone network (PSTN) and 
an intelligent service network (ISN). The switch controller provides control over 
ISN components, including one or more programmable switches, manual operator 
consoles, and automated response units (ARUs). In addition, the switch controller 
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is capable of performing complex call processing to handle service specific 
features of enhanced telecommunications services. 

The resource management routine comprises electronic libraries referred 
to as resource manager tables residing in memory of the switch controller that 
store information about resources and resource management application 
programmer interfaces (APIs) that are used to access the stored information. 
Resource management APIs are stored in the main memory and processed by the 
processor of a computer. In order to process the resource management API, the 
processor calls the resource management API procedure from main memory. The 
resource management API procedure executes commands using input data. The 
resource management API returns a response message that includes requested 
information and/or indication of whether the transaction was successful. The 
resource management API also results in an action requested by the initiating 
routine. 

2. 0 Example Resource Management Environment 

FIG. 1 is a block diagram of an exemplary embodiment of a resource 
management environment 1 02 according to one embodiment of the present 
invention. The switch controller 112 within the ISN 126 provides access for a call 
initiated via telecommunications switching network 108 to ISN components 122a, 
122b, ...122n also within ISN 126. Except as otherwise noted, when the ISN 
components 122 are referred to generally, they will be referred to by number 
designation only and not a letter designation. The resource management routine 
which resides in memory of the switch controller 1 12 provides management of 
ISN 126 resources. The ISN 126 is described in further detail in copending U S 
Patent Applicatioi^Attemey- Docket No^€©R=9-7-ee^7-( 1 595.2790000) entitled, 
"Intelligent Service Network," incorporated by reference herein in its entirety. 

The ISN environment 102 includes telephone 104 used by a caller, a 
telecommunications switching network 108, and an ISN 126. The telephone 104 
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used by the caller is connected to telecommunications switching network 108. 



connectivity to the ISN 126. The ISN components 122 provide enhanced service 
call processing and coimectivity to external networks and resources. Enhanced 
services include manual operator service, prepaid calling, calling card, 1-800- 
COLLECT, and 1-800-MUSICNOW. External networks and resources include 
financial processors, information databases, and Internet facilities. 

The ISN 126 includes a programmable switch 1 10, a switch controller 1 12, 
LANs, WANs, and routers 120, and ISN components 122. The programmable 
switch 110 is connected to the telecommunications switching network 108 to 
provide switching capabilities for access to the ISN 126. The switch controller 
112 is interconnected to programmable switch 110 to provide commands to 
control the programmable switch 1 10. The LANs, WANs, and routers 120 are 
connected to switch controller 112 and the ISN components 122 to provide 
connectivity between the switch controller 112 and the ISN components 122. 
Exemplary ISN components 122 include manual operator consoles (MOCs), 
automated response units (ARUs), databases, and protocol converters. The 
MOCs and ARUs are personal computers (PCS) that interact with a caller to 
provide operator services, customer services, and other enhanced services. 
Databases contain stored information and may be a single database or multiple 
databases connected to and controlled by a server systems. Protocol converters 
are connected to extemal networks and resources and provide protocol conversion 
and other processing necessary for interface between the telecommunications 
switching network 108 and extemal networks and resources. 

The exemplary embodiment of a resource management environment 102 
can best be described referencing the processing of a typical call. The exemplary 
call will be for a service that requires human operator intervention. The call is 
placed by a caller using telephone 104. The call is received by telecommunications 
switching network 108. The telecommunications switching network 108 
comprises multiple telecommunications networks including local exchange 
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networks and interexchange networks. A local exchange network comprises 
switches and termination equipment within a localized area. An example of a local 
exchange network is a local telephone operating company network, such as Bell 
Atlantic. An interexchange network comprises a plurality of switches, also 
referred to as exchanges, distributed throughout a geographic area large enough 
to process long distance telephone calls. For example, a national interexchange 
network comprises switches located throughout the nation. When the call is 
routed to either a local exchange network or an interexchange network, the call 
is routed to one or more switches within the network. 

The telecommunications switching network 108 is interconnected to the 
programmable switch 1 10 within the ISN 126. The programmable switch 1 10 has 
a basic switching matrix that provides switching functionality for access to the ISN 
126. An ISN 126 may include additional programmable switches (not shown) 
interconnected to switch controller 1 12 or to additional switch controllers (not 
shown). The programmable switch is a dumb switch that can connect ports and 
process calls based on external commands. Examples of programmable switches 
include those built by Excel and Summa Four. Excel programmable switches 
come in sizes ranging from 512 ports to 8,000 ports. 

The ISN 126 has a sizable architecture because the number of 
programmable switches 110 and the configuration of the programmable switches 
1 10 can vary depending on the desired port requirement of the ISN 126. Excel 
programmable switches can support various signaling systems such as Signaling 
System Number 7 (SS7) and can be connected directly to the signaling network 
of a telecommunications switching network 108. If multiple programmable 
switches are interconnected to one or more switch controllers, connections 
between the programmable switches and the switch controllers are most likely via 
a LAN (not shown), such as an Ethernet LAN, using transmission control 
protocol/internet protocol (TCP/IP). Transmission control protocol/internet 
protocol is used by various data networks including many Internet servers. 
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Each programmable switch 1 10 is connected to the telecommunications 
switching network 108 via voice telephony trunks, also referred to as lines. 
Typical telephony trunks are capable of carrying high speed digital data. The 
voice trunk connectivity between the programmable switch 110 and the 
telecommunications switching network 108 includes signaling, such as SS7 
protocol. The current industry standard of SS7 protocol is published in the 
Intemational Telecommunications Union (ITU) Signaling System Number 7 (SS7) 
Integrated Services Digital Network (ISDN) User Part (ISUP) NCTl.l 13 (1995) 
document and the International Telecommunications Union (ITU) Signaling 
System 7 (SS7) Message Transfer Part (MTP) NCT 1.111 (1992) document 
which are incorporated herein by reference in their entirety. Signaling System 7 
may be implemented using SS7 signaling rings (not shown) connected to a signal 
transfer point (not shown). Some ISN 126 architectures may use signaling 
gateways between the signaling transfer point and the programmable switch 
although this is not necessary if the programmable switch is capable of the 
signaling used by the telecommunications switching network 108. 

Switch controller 1 12 is connected to programmable switch 1 10 to provide 
extemal commands to control call processing. The switch controller 112 provides 
the commands to the programmable switch 110 to perform call processing 
functions. When the programmable switch 1 10 receives a call from the network 
it sends a message to the switch controller 112. The switch controller 112 
determines the call processing needed and returns commands to the programmable 
switch 110. 

In addition, the switch controller 112 provides access to ISN components 
122. The switch controller interfaces with ISN components 122 via LANs, 
WANs, routers (or any other connectivity) 114 using Network Information 
Distribution System (NIDS) Sequenced Packet Protocol (NSPP) on top of User 
Datagram Protocol/Internet Protocol (UDP/IP). Network Information 
Distribution System Sequenced Packet Protocol is a session oriented packet 
exchange protocol that is implemented over UDP/IP. It is designed to allow rapid 
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information exchange between client applications and NIDS server processes. The 
use of TCP/IP between switch controller 1 12 and the programmable switch 110 
and the use of NSPP/UDP/IP for communications via LANs, WANs, routers (or 
any other connectivity) 1 14 illustrate exemplary protocols but the ISN 126 is not 
limited to these protocols. 

Stored within memory of the switch controller 1 12 is the switch controller 
application program 118 which is the computer program that performs the 
functionality associated with switch controller 112. The switch controller 
application program 1 1 8 is processed by a processor. The architecture of the 
switch controller 1 12 will be described in further detail with respect to FIG. 2. 

The resource management routine 1 14 resides in memory of the switch 
controller 112 within the switch controller application program 118. In one 
embodiment of the present invention, the resource management routine is within 
a resource control function. The resource control function is a process within the 
switch controller application program 118 that both provides management of 
resources and monitors resources. Resources are managed by the resource 
management routine 1 14. Monitoring is performed by a system control process, 
also within the resource control process. The system control process monitors call 
states and service related resources. 

Switch controller application program routines 116A, 116B, 116C, ... 
1 16n reside in memory of the switch controller 1 12 within the switch controller 
application program 1 1 8 and, when executed, perform enhanced service call 
processing and other functions needed to provide an interface between the 
telecommunications switching network 108 and the ISN components 122. Except 
as otherwise noted, when the sv^tch controller application program routines 116 
are referred to generally, they will be referred to with the number designation only 
and not a letter designation. The routines within the switch controller application 
program 1 1 8 include the resource control function (described above), the 
programmable switch support function, the call control function, the service 
control function, and the management interface function. 
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The programmable switch support function provides an interface between 
the switch controller 1 12 and the programmable switch 1 10. The programmable 
switch support fimction translates messages between a generic switch controller 
API message format and programmable switch API message format, manages 
message header/trailer requirements, and controls connectivity to the 
programmable switch 1 10. 

The call control function provides service independent call processing. 
The call control function performs call processing by analyzing call processing 
information with respect to the current state as defined by the basic call state 
machine model. Each call has two states represented in the state machine for the 
originating and terminating call segments. The basic call state machine model is 
described further in the International Telecommunications Union (ITU) 
specifications Q.1224. The call control function performs various functions 
including but not limited to: detecting an incoming call, creating an originating call 
model, collecting originating dial digits, requesting analysis of the digits, selecting 
trunk groups, creating a terminating call model, composing and sending messages 
to the terminating agent or party, detecting ISUP messages, detecting disconnect 
signals, and triggering enhanced services. 

The call control function trigger features and services fi-om the service 
control function. The service control function provides an interface to the ISN 
126 and one or more service logic programs that provide enhanced service call 
processing. The service control function is made up of the switch service process, 
the group select process, call queuing process, and the prepaid service logic 
process. In order to provide an interface to the ISN 126, the switch service 
process connects between SCAPI used by the switch controller and NSPP used 
by ISN 126. 

The management interface function includes two functional areas of 
monitoring control. The system monitoring functionality encompasses the 
generation of system alarms which allows a system management console to 
monitor the status and run-time operation of the switch controller software. The 
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management interface function also includes the process manager, which is 
responsible for initial startup and health of individual processes which make up the 
switch controller 112. 

The ISN components 122A, 122B, ... 122n (122) include components that 
provide enhanced service functionality call and connectivity to external networks 
and resources. Except as otherwise noted, when the ISN components 122 are 
referred to generally, they will be referred to with the number designation only and 
not a letter designation. One example of an ISN component 122 is the MOC. The 
MOC is PC workstation that is operated by a live operator or call center agent to 
provide operator services, customer services, and other enhanced services 
requiring human operator intervention. Another example of an ISN component 
122 is the ARU. The ARU is comprised of a network audio server (NAS) and an 
automated call processor (ACP). The ARU is used to provide automated operator 
services and interactive voice response services. The ACP is a high performance 
personal or midrange computer that performs intelligent application processing to 
determine which services to provide. The NAS is a specialized computer 
equipped with telephony ports which provides audio responses and collects caller 
input via dual tone multifrequency (DTMF) signals and voice recognition based 
on commands provided by the ACP. The ACPs commimicate with the NASs via 
LANs, WANs, and routers 120. Each ARU/NAS and MOC is connected to one 
or more programmable switches via voice trunks (not shown). Both MOCs and 
ARUs are also referred to as agents. 

An additional example of an ISN component 122 is a NIDS server and 
database. A NIDS server and database stores data related to call processing such 
as customer accounts and routing translations. When an ISN component, such as 
an ARU or a MOC, receives a call, it may query a NIDS server for data stored in 
the NIDS database. The NIDS servers receive data from mainframe-based 
systems to be used during real time call processing. Order entry and data 
management functions are performed wdthin mainfiame based systems. Mainframe 
computers are used as the databases of record for call processing data. A data 
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distribution system (DDS) distributes the call processing data stored in the 
mainframe computers over a token ring LAN to each NIDS server. 

The ISN components also include protocol converters that convert 
between various telecommimications protocols. Protocol converters provide 
protocol conversion between different protocols such as TCP/IP, NSPP on top of 
UDP/IP, and packet switching protocols, such as X.25. Exemplary components 
that perform protocol conversion are described in U.S. Patent Application No. 
08/967,339 filed October 21, 1997 entitled, "Advanced Intelligent Network 
Gateway" and U.S. Patent Application No. 08/956,220 filed October 21, 1997 
entitled, "Validation Gateway," both of which are incorporated herein by reference 
in their entirety. Additional ISN components 122 are described in copending U.S. 
Patent Application No. 08/956,232 filed October 21, 1997 entitled, "A System and 
Method for Providing Operator and Customer Services for Intelligent Overlay 
Networks," incorporated herein by reference in its entirety. 

Additional ISN components 122 include standalone PC workstations for 
system management, force management and configuration provisioning. 

Some ISN components 122, such as protocol converters, are connected 
to external networks and resources. Exemplary external networks and resources 
include financial processors with credit card information, the Internet, and other 
databases, such as those used in processing international calls. 

3.0 Resource Management within the Switch Controller 

The switch controller application program 118 of the present invention is 
preferably implemented using a computer system 202 as shown in block diagram 
form in FIG. 2. The computer system 202 includes one or more processors such 
as processor 206 connected to bus 204. Also connected to bus 204 is main 
memory 208 preferably random access memory (RAM) and secondary storage 
devices 210, secondary storage devices 210 include for example a hard drive 212 
and a removable storage medium storage device 214 such as a disk drive. 
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The switch controller application program 1 18 is preferably a computer 
program that resides in main memory 208 while executing. Thus, the switch 
controller application program 1 1 8 represents the controller of the computer 
system 202 (and of the processor 206). Alternately, the switch controller 
application program 1 18 is predominantly or entirely a hardware device such as 
a hardware state machine. 

In one embodiment, the present invention is a computer program product 
such as removable storage medium 216 representing a computer storage disk, 
compact disk etc., comprising a computer readable media having control logic 
recorded thereon. The control logic, when loaded into main memory 208 and 
executed by processor 206, enables the processor 206 to perform operations as 
described herein. The switch controller application program 118 includes 
conmiands which comprise the resource management routine 1 14 which, in one 
embodiment of the present invention, reside in main memory 208 and are 
processed by the processor 206. 

FIG. 3 is a block diagram of a resource management environment 302 
according to one embodiment of the present invention. The block diagram of a 
resource management environment 302 illustrates the protective layer concept of 
the resource management routine 1 14. Within the resource management routine 
114 are resource managers 304A, 304B, 304C ... 304n (304). Resource 
requesters 306A, 306B, 306C ...306n (306) obtain information about resources 
31 OA, 31 OB, 3 IOC ... 31 On (310) by communicating with the resource managers 
304. Thus, the resource managers 304 provide a protective layer for the resources 
310. Except as otherwise noted, when the resource managers 304, resources 310, 
and resource requesters 306 are referred to generally, they will be referred to with 
the number designation only and not a letter designation. 

The resource management routine 1 14 comprises the resource managers 
including resource manager (1) 304A, resource manager (2) 304B, resource 
manager (3) 304C, and resource manager n 304n. 
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Resources 310 include the equipment comprising the ISN 126 and 
enhanced service call processing information. Equipment comprising the ISN 126 
includes the components comprising the programmable swatch 1 10, components 
comprising the switch controller 1 12, and ISN components 122. Examples of 
components comprising the programmable switch 110 are ports, central 
processing unit (CPU) capacity, switch matrix, etc. Examples of components 
comprising the switch controller 1 12 are CPU capacity, shared memory capacity, 
etc. In addition, enhanced service call processing information is a resource 310. 
Enhanced service call processing information includes information about enhanced 
service calls, such as call identification numbers, leg identifiers, billing time points, 
etc. 

Resource requesters 306 include the switch controller application program 
routines 1 16 (system control process, programmable swdtch support function, call 
control function, service control fimction, and management interface function). 
In addition, any routine in a computer program in a telecommunications network 
component that can access the resource management routine 114 may be a 
resource requester 306. 

Each resource manager 304 provides a protective interface for a particular 
corresponding resource 310. For example, resource manager (1) 3 04 A provides 
a protective interface for resource (1) 310A. If a resource requester 306 wants 
information about a resource 310, the resource requester interfaces with the 
appropriate resource manager 304. For example, FIG. 3 illustrates resource 
requester (3) 306C requesting information from both resource manager (1) 304A 
to gain information about resource (1) 31 OA, and resource manager (3) 304C, to 
gain information about resource (3) 3 IOC. If resource requester (3) is the service 
control function, the service control function may request information about 
agents and call data block information. The service control function would access 
a resource manager for information about the agents and another resource 
manager for information from the call data block. 
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Multiple resource requesters 306 may obtain information about a resource 
3 10 by accessing the appropriate resource manager 304. For example, resource 
requester (1) 306A and resource requester (2) 306B request information from 
resource manager (2) 304B to gain information about resource (2) 31 OB. If the 
programmable switch support function and the management interface function 
need information about a component of the programmable switch 110, both 
routines access the resource manager 304 corresponding to the programmable 
switch component 1 10. 

FIG. 4 is a block diagram of a resource management interface 402. The 
resource management routine 1 14 provides the resource management interface 
402. The resource management interface 402 illustrates that in order to access 
information about a resource 310, a resource requester 306 accesses the 
appropriate resource manager 304. Exemplary resource requester (1) 306A 
accesses resource manager (2) 304B to obtain information about a corresponding 
resource (2) 31 OB. If exemplary resource requester (1) 3 06 A needs information 
about resource (1) 3 1 OA or resource « 3 lOn, the resource requester (1) 3 06 A will 
access the corresponding resource manager 304, particularly resource manager (1) 
304A or resource manager « 3 lOn respectively. As a result, information about 
resources 3 1 0 is accessed in a standardized manner by each of the resource 
requesters 306. In addition, the resource requesters 306 are not required to have 
individual procedures for accessing information about resources 3 1 0. Rather, the 
resource requesters 306 use the generic procedures within the resource manager 
304. 

Each resource manager 304 includes one or more resource manager 
application programmer interfaces (APIs) 404 and one or more resource manager 
tables 406, referred to interchangeably as electronic libraries. For example, 
resource manager (1) 304A includes resource manager API(s) (1) 404A and 
resource manager table(s) (1) 406a; resource manager (2) 304B includes resource 
manager API(s) (2) 404B and resource manager table(s) (2) 406B; and resource 
manager n 304n includes resource manager API(s) n 404n and resource manager 
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table(s) n 406n. Except as otherwise noted, when the resource manager APIs 404 
and resource manager tables 406 are referred to generally, they will be referred to 
with the number designation only and not a letter designation. 

The resource manager tables 406 reside in memory of the switch controller 
and store information about resources 310. The resource management APIs 404 
are procedures that are used to access the stored information. Resource 
management APIs 404 are commands that are stored in the main memory and 
processed by the processor of a computer. In order to process a resource 
management API 404, the processor calls the resource management API 404 from 
main memory. The resource management API 404 processes by executing 
commands using input data. Completion of the execution of the resource 
management API 404 results in return data which is the data requested and/or data 
indicating whether the transaction was successful and an output which is an action 
requested by the initiating routine. 

FIG. 5 illustrates the operation of resource manager process flow 502. In 
step 506 the resource requester sends a query to the appropriate resource manager 
304 using the resource manager API 404. For example, as shown in FIG. 4 
resource requester (1) 306A would send a query using the resource manager API 
(2) 404B to resource manager (2) 304B to access information in resource manager 
tables (2) 406B. The switch controller uses UNIX interprocess communications 
(IPC) capabilities in order to facilitate communication among the routines of the 
switch controller. Particularly, UNIX IPC queues and shared memory capabilities 
are used. 

Switch controller application program routines 1 16 send queries to well 
known IPC queues. The queries contain a reference pointer to shared memory. 
The shared memory is dynamically allocated and contains data needed to perform 
the resource manager API 404 request. The processor 206 (shown in FIG. 2) 
executes the resource manager API 404 commands residing in memory which 
preferably is main memory 208 but may be secondary memory 210 including hard 
disk 212 or a removable medium 216. In the example above, the processor 
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executing the resource manager (2) API 404B commands generates a query which 
is sent from the resource requester (1) 306A (shown in FIG. 4 and FIG. 3) to a 
queue associated with resource manager (2) 304B. The queue includes a 
reference pointer to shared memory with data needed to retrieve information 
about the resource 310. 

For example, if the resource requester 306 is the call control function, an 
exemplary communication is the call control function writing call information to 
the call data block. In the example, the call information is the resource (2) 31 OB. 
The call control function will send a query using the call data block resource 
manager API 404 to set information in the call data block. The call data block is 
the resource manager table 406. 

In step 508 data is retrieved or updated in the appropriate resource 
managers table 406. In order to retrieve data from or update a resource manager 
table 406, the resource manager 304 retrieves the reference pointer contained in 
the query that was sent in step 506, accesses the shared memory pointed to by the 
reference pointer, and retrieves data from shared memory needed to retrieve data 
from or update the resource manager table 406. In the example illustrated in 
FIG. 4, the resource manager (2) 304B retrieves the reference pointer in the query 
sent by resource requester (1) 306A in step 506, accesses the shared memory 
pointed to by the reference pointer, and retrieves the data from shared memory 
needed to retrieve data from or update the resource manager table (2) 406B. 

After retrieving the data from shared memory, the resource manager 304 
performs the requested resource manager API 404 procedure which involves 
retrieving information from or updating the resource manager table 406. In the 
example illustrated in FIG. 4, the resource manager (2) 304B performs the 
resource manager API (2) 404B procedure and refrieves information from or 
updates resource manager table (2) 406B. 

For an exemplary request by the call control function to write information 
to the call data block, the call data block resource manager will retrieve the 
reference pointer from the query sent by the call control function (which is the 
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resource requester 306). The call data block resource manager will access shared 
memory pointed to by the reference pointer and retrieve the data from shared 
memory to retrieve data from or update the call data block, which is the call data 
block resource manager table. Exemplary data includes a call identifier that can 
be used to access the call data block information for a particular call. The call data 
block resource manager will write the data to the call data block. The call data 
block resource manager API and call data block table will be described in further 
detail with respect to FIG. 6. 

To ensure that multiple resource requesters 306 do not access the same 
information within a resource manager table 406, a semaphore variable is set if a 
resource requester 306 is accessing information. A semaphore variable is a 
variable that has two possible values, one value indicating that data may be 
accessed and another value indicating that data may not be accessed. Semaphore 
variables may control access of a table or of just one data element within a table. 
Semaphore variables are resources as they are needed for enhanced service call 
processing. Procedures for retrieving information about or updating semaphore 
variables are defined by the semaphore variable APIs. Information about 
semaphore variables, such as the value of the variable, is stored in a semaphore 
variable table. 

In step 510 the resource manager 304 responds using the resource 
manager API 404. Completion of the execution of the resource manager API 404 
results in return data which is the data requested and/or data indicating whether 
the transaction was successfril. Also, the completion of the execution of the 
resource manager API 404 may result in an output, which is an action requested 
by the initiating routine. Neither return data nor output is necessary for successful 
processing by the resource management API 404 but may be useful in providing 
data and/or ensuring a transaction completed successfully. 
4. 0 Exemplary Resource Management Embodiment 

A. Overview 
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Fig. 6 is a block diagram 602 of an exemplary embodiment of a resource 
management 114. Resource management 114 includes numerous resource 
managers 604-622. In one embodiment, these resource managers include the 
tabman resource manager 604, queman resource manager 606, sysmem resource 
manager 608, shmman resource manager 610, semaphore resource manager 612, 
switch controller resource manager 614, agent resource manager 616, call data 
block resource manager 618, service logic program resource manager 620 and 
switch resource resource manager 622. These various resource managers are 
described in further detail in Tables 1-69. 

B. Tables 

1.0 Tabman Resource Manager 604 

API Tables 

Tabman Client Table APIs 
Tabman Service Descriptor APIs 
Tabman Service Table APIs 
Other Tabman APIs 

Data Structure Tables 

Tabman Client Table Data Structure Table 67 

Tabman Service Descriptor Table 

Data Structure Table 68 

Tabman Service Table Data Structure Table 69 

2. 0 Queman Resource Manager 606 

API Table 
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Queman APIs 



Table 64 



3. 0 Sysmem Resource Manager 608 



API Table 
Sysmem APIs 



Table 65 



4. 0 Shmman Resource Manager 61 0 



API Table 
Shmman APIs 



Table 66 



5. 0 Semaphore Resource Manager 612 



API Table 
Semaphore APIs 



Table 1 



6. 0 Switch Controller Resource Manager 614 



API Tables 

Switch Controller Common Library 

Memory Segment APIs Table 2 

Operational Measurements Area APIs Table 3 

Heartbeat Table APIs Table 4 



Data Structure Tables 
IPC Table 

Switch Controller CPU Availability 
Switch Controller Disk Availability 



Table 12 
Table 13 
Table 14 
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Agent Operational Measurement Counts Table 15 
Switch Port Operational Measurement 

Counts Table 16 

Control Table for Heartbeat Table Table 17 

Heartbeat Table Table 1 8 



7. 0 Agent Resource Manager 61 6 



10 



API Table 

Agent Memory Segment APIs 
Agent Table APIs 
Group Table APIs 
Assignment Table APIs 



Table 5 
Table 6 
Table 7 
Table 8 



15 



20 



25 



Data Structure Table 
Control Table for Agent Table 
Agent Table 
Agent Attributes Table 
Agent Time Stamps Table 
Agent Counts Table 
Control Table for Group Table 
Group Table 

Calls Queued Per Group Table 
Control Assignment Table 
Assignment Table 
Assignment Data Table 
Mapping Table 
Fast Search for Agent Table 
Group Search Table 



Table 19 
Table 20 
Table 21 
Table 22 
Table 23 
Table 24 
Table 25 
Table 26 
Table 27 
Table 28 
Table 29 
Table 30 
Table 31 
Table 32 
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8.0 Call Data Block Resource Manager 618 



API Table 

Call Data Block APIs 



Table 9 



Data Structure Table 
Call Data Block Table 
Leg Data Table 
Port Table 
Time Points Table 



Table 33 
Table 34 
Table 35 
Table 36 



9. 0 Service Logic Program Resource Manager 620 



10 



API Table 

Service Logic Program APIs 



Table 10 



Data Structure Table 
Service Logic Program Table 



Table 37 



10.0 Switch Resource Resource Manager 622 



15 



API Table 
Switch APIs 



Table 1 1 



20 



Data Structure Tables 
Node Information Table 
Card Information Table 
Slot Table 
Node Table Type 
Span Map Table 
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Line Card Table 


Table 43 


CPU Card Table 


Table 44 


DSP Table 


Table 45 


SIMM Table 


Table 46 


MFDSP Table 


Table 47 


Stack Table 


Table 48 


Linkset Table 


Table 49 


Link Table 


Table 50 


Destination Table 


Table 51 


Route Table 


Table 52 


SS7 Table 


Table 53 


EXNET Table 


Table 54 


Facility Table 


Table 55 


Channel Table 


Table 56 


ISDN Card Table 


Table 57 


Other Card Table 


Table 58 


Card Union Table 


Table 59 



C. Description of Exemplary Resource Manager 

The call data block resource manager 618 is described with respect to 
Table 9 to provide an exemplary illustration of the information contained in the 
tables. The call data block resource manager 618 comprises call data block APIs 
and call data block resource manager tables. Call data block APIs are described 
in Table 9. Call data block APIs provide procedures for managing call data block 
information. Call data block information includes call related data obtained in 
processing a call and used to identify the call, elements of the call, such as the call 
legs, and provide information for billing the call, such as billing time points. The 
call data block resource manager tables are illustrated in Tables 33-36. 
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Exemplary cdb_GetCDBData API provides procedures for retrieving call 
data block information from the call data block table. Table 9 provides 
information about the call data block APIs. The first column provides the API 
name. In the exemplary API shown in the eighth row of Table 9, the first column 
indicates the name of the API is cdb_GetCDBData. The second column of Table 
9 indicates the fionction. With respect the exemplary API cdb_GetCDBData, the 
fiinction is to get a CDB's detailed data. The third column of Table 9 provides 
input parameters. For the exemplary API, cdb_GetCDBData, the inputs required 
are the 1 Cid, which is the call identifier, and the pstCDBData, which is the 
address of where the CDB data should be saved. The fourth column of Table 9 
provides the output of the API. For the exemplary cdb_GetCDBData API, the 
output is saving the CDB data at the pstCDBData address. The fifth column 
provides the return of the API. For the exemplary cdb_GetCDBData API, the 
possible returns are: CDB SUCCESS, CDB_SHM_NOT_ATTACH, 
CDB_KEY_IN VALID, C D B _I N P U T_ A D D R_I N V A L I D , 
CDB_LOCK_REC_ERR, and CDB_UNLOCK_REC_ERROR. 

D. Description of Other Resource Managers 

Additional resource managers are described in the tables. The semaphore 
resource manager 612 comprises semaphore APIs and semaphore resource 
manager tables. In Table 1, semaphore APIs are described. Semaphore APIs 
provide procedures for managing semaphore variables. Semaphore variables are 
UNIX constructs that lock and unlock memory segments. The semaphore 
variables within the switch controller 1 12 provide controlled access to data related 
to ISN resources. A set of semaphore variables is created for each table for access 
to the resource data stored in the table. Semaphore variables act as gatekeepers 
for memory by preventing multiple processes fi-om accessing a particular memory 
segment simultaneously. The number of processes that may access a memory 
segment may be adjusted by modifying a configurable variable. The value of the 
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configurable variable establishes the threshold value of the number of processes 
allowed access. Two locking schemes for semaphore variables are locking of an 
entire table and locking of one entry within a table. The semaphore resource 
manager tables may be any semaphore table such as those traditionally used with 
UNIX platforms. 

The switch controller resource manager 614 comprises switch controller 
APIs and switch controller resource manager tables. The switch controller 
resource manager APIs and switch controller resource manager tables include (1) 
switch controller common library APIs, (2) operational measurements area APIs 
and tables, and (3) heartbeat APIs and tables. 

In Table 2, switch controller common library APIs are described. The 
switch controller common library APIs affect the switch controller common library 
memory segment. The switch controller common library memory segment 
supports shared memory used to store heartbeat information and provides an 
operational measurements area where processes can deposit statistical data. 
Switch controller common library APIs are used to create and delete the switch 
controller common library memory segment. In addition, switch controller 
common library APIs are used by routines to attach and detach from the switch 
controller common library memory segment. 

In Table 3, operational measurements area APIs are described. 
Operational measurements area APIs provide procedures for managing operational 
measurements data. Operational measurements data includes statistics of the 
components of the switch controller, such as disks, central processing unit (CPU) 
available memory, ports, and other similar data. Tables 12-18 provide additional 
information describing the tables used to store operational measurements data. 

In Table 4, heartbeat table APIs are described. Heartbeat table APIs 
provide procedures for managing heartbeat data. Heartbeat functionality is used 
to monitor the health of the processes within the switch controller 1 12. A process 
manager routine within the management interface function is responsible for 
sending heartbeat requests to other switch controller application program routines 
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1 16 within certain intervals. The recipient switch controller application program 
routines 116 are responsible for responding to the heartbeat requests within 
established intervals. Process management determines when and what action 
should be taken when a process is not responding in a proper maimer. 

Heartbeat requests and responses are conveyed by setting request and 
response flags through shared memory. Heartbeating through shared memory is 
more efficient than heartbeating by sending messages through message queues 
because heartbeating through shared memory reduces the message volume within 
the switch controller. 

Use of shared memory for heartbeating is described. The shared memory 
segment used to perform heartbeating is referred to as the heartbeat area. In one 
embodiment, one of the switch controller application program routines 1 16 is-a 
process manager. A process manager oversees the heartbeating function and uses 
a resource management API to create the heartbeat shared memory segment. 
Within the shared memory segment, an entry is created for each switch controller 
application program routine 116. The entry contains heartbeat information, such 
as the switch controller application program routine identifier, heartbeat interval, 
heartbeat state (eg. register, request, or respond), request time stamp, and 
unresponded time and count. Heartbeat intervals can be set to different values for 
different switch controller application program routines 116. Table 18 provides 
an exemplary table used to store heartbeat data. Table 17 illustrates an exemplary 
control table used to control the heartbeat table. 

The process manager brings up each of the other switch controller 
application program routines 1 16. The switch controller application program 
routines 116 attach to the heartbeat segment. To initiate processing with a 
particular switch controller application program routine 1 16, the process manager 
uses a resource management API to register each switch controller application 
program routine's 1 16 heartbeat entry and establishes its heartbeating interval. 
The interval may be modified using another resource management API. 
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The process manager informs each of the switch controller application 
program routines 1 16 of the need for heartbeating by sending a message with the 
switch controller application program routine's 116 heartbeat handle. The process 
manager calls a heartbeat request API to indicate a heartbeat request. When the 
routine 116 receives an initial heartbeat setup message, it immediately calls a 
respond heartbeat API. Each time a process calls a respond API, it will get a time 
which tells the process when it should next call the respond API. The routines 
1 1 6 can get the current set heartbeat interval time using this API as well. Wbi 
switch controller application program routines 116 exit, they detach from the 
memory segment. During switch controller 112 shutdown, a delete heartbeat 
segment is called to remove the segment from the system. 

Additional resource managers are described in the tables. The agent 
resource manager 616 comprises agent APIs and agent resource manager tables. 
Agent APIs include APIs to manage agent, group, and agent assignment tables. 
Agent table, group table, and assignment tables are stored in one shared memory 
segment and share the same shared memory identifier. In Table 5, agent memory 
segment APIs are described. Agent memory segment APIs provide procedures 
for managing the agent memory segment. Agent memory segment APIs are used 
to create and delete the agent memory segment. In addition, agent memory 
segment APIs are used by routines to attach and detach from the agent memory 
segment. 

In Table 6, agent table APIs are described. Agent table APIs provide 
procedures for managing agent tables. Agent tables include information about 
agents, such as terminal identifiers, agent logon identifiers, and associated groups. 
After an agent establishes a connection with the switch controller and logs on, its 
operating state in an agent table will be updated as capable of processing calls. In 
addition, after the agent logs off, its operating state will be changed to unable to 
handle calls. An agent API is provided to find an agent within a particular group. 
In addition, APIs to dynamically add and delete an agent entry are also provided. 
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Tables 20-23 illustrate tables used to store information about agents. In addition, 
Tables 30-32 provide tables used to store general information about agents. 

In Table 7, group Uble APIs axe described. Group table APIs provide 
procedures for managing the group tables. Agents are grouped together 
according to their call processing functionalities. Agent group information 
includes information about the groups, agents assigned to the group and the 
number of calls queued to the group. Tables 24-26 illustrate tables used to store 
agent group information. 

In Table 8, assignment table APIs are described. Assignment table APIs 
provide procedures for managing the assignment table. An agent group can have 
any number of agents assigned to it and an agent can be assigned to multiple 
groups. In order to describe the cross referencing between the agent table and 
group table, a separate agent assignment table is created. Tables 27-29 illustrate 
tables used to store agent assignment information. 

The service logic program resource manager 612 comprises service logic 
program APIs and service logic program resource manager tables. In Table 10, 
service logic program APIs arc described. Service logic program APIs provide 
procedures for managing the service logic program table. The service logic 
program table contains call identifier, call feature, call state and event information, 
The service logic program table is separate from the call data block. The service 
logic program table is organized on the service level. If a service logic program 
terminates abnormally, the service logic program can attach to this table and have 
access to most of the information needed about the calls in progress. Table 37 
illustrates the table used to store service logic program data. 

The switch resource resource manager 622 comprises switch APIs and 
switch resource manager tables. In Table 1 1, switch APIs are described. Switch 
APIs provide procedures for managing switch data. 

Switch data includes switch matrix, card, node, span, trunk group, and 
other information related to the programmable switch 1 1 0 controlled by the 
switch controller 112. A switch matrix performs the switching functionality of 
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interconnecting two channels, a channel from the caller and a channel to the 
receiver, in order to switch a call to a final destination. A card is a microprocessor 
chip board that is programmed to perform a specialized functionality. Cards 
within the programmable switch 1 10 are programmed with different software to 
perform various functions. Nodes are points of interconnection in a 
telecommunications network. Spans are telecommunications cables, typically fiber 
optic, however any medium capable of transmitting signals may used, that 
interconnect two components in a telecommunications network. Channels are 
bandwidth allocations that may be assigned to a particular call. Trunk groups are 
designations wdthin software that are used for traffic routing purposes. Channels 
are assigned to trunk groups and a particular trunk group routes traffic between 
the destinations interconnected by the channels assigned. When a call is received, 
the destination number is used to select an appropriate trunk group and route the 
call via a channel assigned to the trunk group to the destination. Tables 38-59 
provide additional information describing the tables used to store switch data. 

While various embodiments of the present invention have been described 
above it should be understood that they have been presented by way of example 
only not limitation. Thus the breadth and scope of the present invention should 
not be remitted by any of the above described exemplary embodiments but should 
be defined only in accordance with the following claims and their equivalents. 
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/ice handle 


/ice handle 


Return 


Service count 
BAD CC on error 


TRUE - locked 
FALSE - invalid sen 


TRUE - locked 
FALSE - invalid sen 


Output 














client handle 
- service handle 


client handle 
■ service handle 


Input 


None 




hClientHandle ■ 
hServerHandle 


hClientHandle - 
hServerHandle • 




/ice entries. 






&« 


Function 


Get the number of sen 




Lock the service entry 


Unlock the service ent 


API 


GetServiceCount 


LockService 


UnLockService 
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TABMAN CLIENT TABLE DATA STRUCTURE 



typedef struct ClientTableTyp 
{ 

CHAR achClientName [NIDS_CLIENT_NAME_LEN]; 







/* 


client name 


USHORT 


usAddressFamily; 


/* 


NIBS address or UP address 


NIDS_ADDRESS 


stClientAddress; 


/* 


client address 


NIDS_UDP_SOCK 


ADDRESS 








StClientUDP Address; 


/* 


client UP address 


ULONG 


uILastReceived; 


/* 


last packet received time 


SHORT 


sWDCount; 


/* 


unresponded watchdogs 


USHORT 


usCurrentPacketNum; 


/* 


control data 


USHORT 


usReceivedPacketNum; 


/* 


last received packet sequence num. 


USHORT 


usLastSendablePacketNum; 








/* 


last sendable packet seq. num. 


USHORT 


usClientsLastSendable; 


/* 


client last sendable packet 


VOID 


*pstNewList; 


/* 


new packet list 


VOID 


*pst01dList; 


/* 


old packet list 


BOOL 


ProtectField; 


/* 


used by table handler 


BOOL 


fCIientUsed; 


/* 


Client entry used 


USHORT 


hServiceHandle; 


/* 


Service Handle 


USHORT 


hNextClientHandle; 


/* 


handle of next client (used element) 


USHORT 


hPrevClientHandle; 


/* 


handle of Pre client (used element) 



} ClientTableTyp; 
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TABMAN SERVICE DESCRIPTOR TABLE DATA STRUCTURE 



typedef struct DescTableTyp 
{ 



CHAR 

UCHAR 

BOOL 

USHORT 

QHAND 

VOID 



ULONG 

ULONG 

DescTyp 

BOOL 

BOOL 

USHORT 

USHORT 

USHORT 

} DescTableTyp; 



achServiceName [NIDS_SERVICE_NAME_LEN] ; 





/* service name 


*/ 


uchServiceType; 


/* service type flag 


*/ 


fDisabled; 


/* service status 


*/ 


usConsoles; 


/* number of clients 


*/ 


hQueucHandle; 


/* handle of process queue 


*/ 


*pvMessage; 


/* pointer to any message that you 


*/ 




/* may want to store 


*/ 


uIHostSendDiskQues 


/* Disk queues for a pzirticular Hostsend 


*/ 


ulBdrSendDiskQues; 


/* Disk queues for a particular Bdrsend 


*/ 


stDesc; 


/* union of service description 


*/ 


ProtectField; 


/* used by table handler 


*/ 


fServiccDescUsed; /* 


Service Desc Used ? 


*/ 


hServiceHandle; 


/* handle to service table 


*/ 


hNextDescHandle ; 


/* next service description 


*/ 


hPrevDescHandle; 


/* Prev service description 


*/ 
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TABMAN SERVICE TABLE DATA STRUCTURE 



Typedef struct ServiceTableTyp 



SrvcTyp 

QHAND 

void 

BOOL 

BOOL 

USHORT 

USHORT 

USHORT 

USHORT 

USHORT 

USHORT 

} Sei-viceTableTyp; 



stSrvc; 

hQueueHandle; 

*pLocalRespMsg; 

ProtectField; 

fServiceUsed; 

hClientHandle; 

hNextClientService; 

hPrevClientService; 

hNextServiceHandle; 

hPrevServiceHandle; 

hDescHandle: 



/* service type 

/* handle of process queue 

/* Call reorigination 

/* used by table handler 

/* Service Used ? 

/* client handle to client table 

/* next client Service 

/* Prev client Service 

/* forward next service 

/* backward next service 

/* Service Description Handle 



*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
*/ 
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or 


or 
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urn 


CC 


CC 


CC 


Keti 


OK 


OK 
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Output 














■ attached 








ress ■ 
















Input 


None 


None 


puchSharedy 
address 


Function 


Initially create the SYSVARS 
shared memory segment and 
semaphore. 


Attach to the SYSVARS memory 
segment. 


Detach from the SYSVARS 
memory segment. 


API 


CreateShmSystemVars 


AttachSysvarsSharedMem 


DetachSysvarsSharedlVlem 



# 



u 
u 

I 

Q 
< 
OQ 



O 



■ tu 



T3 



■is ai 



o (2 



•T3 
X) 



u 

c 
o 



< 
CQ 



o 



u 
< 

OQ 



O 

o 



CJ 



u u 
E ^ 
a> , 

CO 

■ U 
flj • — 

N 00 

W) O 

00 CQ 



c 
o 



E 

3 



o 00 
(3 O 

.£3 ^ 



eo . 

c3 <L> 

> c 



UJ 

N <U 
- ^ 



■ -.5 -is ^ 



3 3 3 3 



m dj 



00 



CO 

o 



Pi 
< 

I- 

o 



o 
o 
a. 



a 



<u 
E 

E « 



S 8 

u ® 

.2 « 

s 

•- o 

•a E 
_ 



o 
E 

E 



CO 



m 
C 
o 



o 
o 
a. 

E 

oo 
c 
?-> 
Q 



o 
o 

Oh 

E 



Q 
< 



•T3 



CO W 

o <; 
c 

« o 



o 

00 o- 



w 
S 

< 

o 
►J 

< 

C/3 



O 
O 



•15 



o W 



•a 

o . — , 
o o 

> " 



o 
oi 

o 
_) 



o 
o 



T3 

e 

CO 



CO 

E 
o 

<£: - 

o 

g 
E 



<u 



O (U 

° cS 
JO ja 



CO E 

,E 

o 2 

E E 

S <u 

E E 

IS ra 

CO 

— « 

CO CO 

to o 



■4-* O ^ 



CO 



•a 

•a h 

CO 



£J .S . 
•2 >,c 

§■1 E 

^ 8 So 

c 5 S 
f < E 

tj o JS 

« § E 

QJ g QJ 

cn o V] 



I ^ 
« I" 

S i 



<u 



-^5 .E 

JO <u 
CJ _co 



CO 5 

3 O 

5 o 
.SP n 

4-i q> 

s £ 

O CO 

" •S g. 

e|I 



o 
o 



oo 
c 
>1 

Q 
u 
o 



o 
o 

CO 
> 

<: 

E 

00 

c 



00 

c 
Q 



o 
o 
a. 

E 

00 

c 

Q 

E 
o 
U 




O V3 

o u 

u cr 

o y 



^ u 



— o 
•2 >. 

o = 



u (J 



■3 £ S 
— C o 

.= 3 



ft> o 



> Q. 



o 



' — ^ J2 ^ — "5 

= S =■ -^.2 

•- 3 ■- 

^ cr « j3 — 
^ J> ^ ra in 



o 



^ 4) 



IS o 



CJ o 



o 

i4 fc 
O W 



o 

O ^ 



o 



o 
t 

o ° 



i 

o ? 



o 

O " 



o 



CO 



cd 

E 

e 



u u C 

x; x: 

to cB 



_o on 
C O 



E S 



E 



■ is 



s E 
a. " 

B to 



OJ 



60 K 
^ o 
</i tu ■ 
a E 



u 

>■ _ 

o ^ 
tt 

e 

t/5 



H o 

u o 

v: cd 

° s 

g .E 

E 2 

3 60 

i I 

V E 

W5 va 



60 



O 



Cu — 



tS -2 ° 

E « 

M CO 5 

3 ^ CO 



O. 

cd 

E 

u 

S? ^ 
CS x> 

CO CO 



4> cd 



n) 22 H 
— o. o, 

5 cd cd 

SEE 
c u u 



Cd 2 

Sd E 



o 
a. 



E 
u 

C/3 



o 
a. 

<d V 



60 

E 



•a 

E 
u 

CO ^ 
Cl ~ 



60 _ 
cd o 

E-g. 



& E 2 



g S ^ 

w . Q 

60 z 
cd 

EES 

CO 00 W 

- on C/3 



O 



■ Q 

60 r 
EEs 

00 00 W 



cd ^ u 

u o o 

.ti J= 4= 

— ex O. 

2 CO c? 

.ti E E 

C 4> u 



o 
Q 

y - 

f I 

E E 

cn 

j= .s 



o 



© 
o 



B 

s 



" o 

(JO — 
c u 



"2 •?? 



r? cn 



.a 0, 



S 5 S § 5 ^ 



o IS 
o 



•- O ^ U 

s o c i 

5 <« E H 

t3 « Si o 

-o ^ c — . 

— — o 



ca "D 

I- o 

g " 



to , 



^ T 



.t; « 



c c 

u u 

E E 

a Si 

c a 



B 3 

^ op 



-o" S 

3 C 



^ < 



o 

O " 



o 

Q 



— oo 

E H 
o :S 

3 .2 

§ ° 

p JO o 

o o. 



■ o E 

" CO 

C" ■ 

c £P 

CO a> 
H en 

CO f/i 



o 

o -9 



iJ to 
3 O 
C 00° 

.E o. 
-2 y E 



" o E 

o o 

" ■a 

*- J= o 

4J C 

S8 c ° 

CJ tj o 

u E 

S S 3 

o o 

— -a j= 

o " 

^ -2^ CO 

I— I < — ' ^ 



E^ 



^ Q h- 



o 



E oo 

O cd 

^ c 
o .9 

£> to 



U J3 

o S • 
o. ■ 

E;i. 

c 

u cd 
CO H 



fct- 

to C/5 



O 

C JO 

D 2 



o 

o " 



2 



JO 

E 



c o 

H «> S 

u o o 

l-E E 

2 g S 

E io M 

u . I 

T i 00 

a 2 



00 



W 00 



E 00 

P ea 



is o 



u o 9 

2 a. o. 
•S " 

« i 

E K 

O) 

o 

E I" 

CO to 



■ O 
• Q 

CO CO 



<L> 

ts} U to 

« ° iS 

as ^ 

t 8 ^ 

O. 4> CO 

(d I- 



CO 

^ -s 

r: s 

1) JC o 

O U .5 



o 
fc 
u 

o ° 



1 Q 
a. £3 

2 to 

c to 

^ 0» 



E -o 

C/3 O- 



O. " 

CO 

e 

CO o 

to to 



3 



o S 

« E 

E 2 

« 

<- ^ 

<L> JO 

o M 

S o a. «i 



CO "O 
O ^ 
> « 

n . CO 
.S Q 



o 

o = 



3 

Q 

(U -S 

I 2 

CO u 

E c 
E .H 

tu C/5 
c/2 S3 
cx 



N 2^ 

O 

^ & 

t3 E 

o a 



1^ 



•.5 



3 

jO 



^ tu 



I 



Is 

c5 > 

H sq 



to 



3 



o " 



E S 

U CO 



o ? 




Switch Controller Common Library Memory Segment APIs 



API 


Function 


Input 


Possible Returns 


CM_Create CMSegment 


Creates and initializes the 
sc_common shared memory 
segment, which is composed 
of OM area and heartbeat 
lauic i^icaicb aHQ iniiiauzes 
semaphore sets for OM and 
HB. Primarily used by the 
process manager. 


USMaxNoOf HBEntry 
- maximum number of 
HB entries 


CM_FAIL 


CM_Delete CMSegment 


Deletes the sc common 
share memory segment and 
its semaphore sets. 


None 


CM_SUCCESS 
CM_FAIL 


CM Attach CMSegment 


Attaches to the sc_common 
share memory segment. 


None 


CM_SUCCESS 
CM_FAIL 


CM Detach CMSegment 


Detaches from sc common 
segment. 


None 


CM_SUCCESS 
CMFAIL 
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Switch Controller Common Library Table 
Operational Measurements Area 
IPC Table 



(Contains information pertaining to shared memory, queues, and semaphores.) 



r leld 










ch Name 


IPC 1 


IPC 2 




IPCn 


I Key 










I Id 

(Identifier) 










I Size 










I Create 
Time 











Table 12 



Switch Controller Common Library Table 
Operational Measurements Area 
Switch Controller CPU Availability 



Field 


CPU A 


CPUB 




CPUn 


I Startup Time 










us Available CPU (percent) 










us Waiting CPU (percent) 










ul Total Memory 










ul Available Memory 










St Disk 


pointer to 
St Disk 
table 


pointer to 
St Disk 
table 




pointer to 
st Disk 
table 



Table 13 




m m 



Switch Controller Common Library Table 
Operational Measurements Area 
Disk Availability 



Field 










chName 


Disk 1 


Disk 2 




Disk n 


Total 










Available 











* 2-8 disks per CPU typical 

Table 14 



Switch Controller Common Library 
Operational Measurements Area 
Agent Operational Measurement 
Counts 

For Agents Controlled by a Switch Controller 



Field 


Counts 


ul Agent Total 




ul Agent Disconnect 




ul Agent Connect 




ul Agent Ready 




ul Agent Busy 





Table 15 




Switch Controller Common Library 
Operational Measurements Area 
Switch Port Operational Measurement 
Counts 
for a Switch Controller 



Field 


Counts 


ul Port Total 




ul Port Conference 




ul Port Out 




ul Port In 




ul Port Hold 





Table 16 



Switch Controller Common Library 
Control Table For Heartbeat Table 



Field 


Value 


Comments 


us Max Element 




max element index in the table 


us Use Element 




first element in the used list 


us Free Element 




first element in the unused list 


us Use Counts 




element count 


us Stand Alone 




table is a standalone segment flag 



Table 17 



6% 



Switch Controller Common Library 
Heartbeat Table 



Field 










Comments 


IPid 


Process 1 


Process 2 




Process n 


Process Identifier 


s State 










May be register, request or 
respond 


us Interval 










Heartbeat interval 


us Half 
Interval 










Half of the heartbeat interval 


d Request 
Time 










Last request time stamp 


us Unrsp 
Count 










Heartbeat unrespond counter 


us Unrsp time 










Unresponded elapsed time 


h Prev Handle 










Previous handle 


h Next Handle 










Next handle 


ch Entry Used 










Entry used flag 



Table 18 



Agent Library 
Control Table for Agent Table 



Field 


Value 


Comments 


us Max Element 




Max element index in the table 


us Use Element 




First element in the used list 


us Free Element 




First element in the unused list 


us Use Counts 




Element count 


us Stand Alone 




Table is a stand alone segment flag 


st Agent Count 




Agent count 



Table 19 
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Agent Library 
Agent Table 



Field 










Comments 


St Agent Data 










Agent data substructure 


h Assigned 










Assigned groups 


h Client Handle 










Client handle 


h Prev Handle 










Previous agent handle 


h Next Handle 










Next agent handle 


ch Entry Used 










Entry used flag 



•\9 



10 



Table 20 




Agent Library 
Agent Attributes Table 



Field 










Comments 


ITid 


Agent 
Tidl 


Agent 
Tid2 




Agent 
Tidn 


Agent terminal identifier 


st Agent DN 










Agent destination 
number 


uch Agent Logon ID 










Agent logon identifier 


St Agent Attr 










Agent attribute structure 


St Last Logoff Cause 










Last logoff reason 


s State 










Agent state 



20 



Table 21 



f.9 



0 



Agent Library 
Agent Time Stamps Table 



Field 


Agent 
Tid 1 


Agent 
Tid 2 




Agent 
Tidn 




I Last Connect Time 










Last logon time 


I Last Ready Time 










Last become ready time 


I Last Busy Time 










Last become busy time 


I Last Disconnect 
Time 










Last log out time 



10 



15 

f 




Table 22 



Agent Library 
Agent Count Table 



Field 


Value 


Comments 


us Total 




Total Agent Entries 


us Disconnect 




Total Agents in Disconnect State 


us Connect 




Total Agents in Connect State 


us Ready 




Total Agents in Ready State 


us Busy 




Total Agents in Busy State 



Table 23 



Agent Library 
Control Table for Group Table 



Field 


Value 


Comments 


us Max Element 




Max element index in the table 


us Use Element 




First element in the used list 


us Free Element 




First element in the unused list 


us Use Covmts 




Element count 


us Stand Alone 




Table is a stand alone segment flag 


us Calls Queued 




Total number of calls queued 



Table 24 



Agent Library 
Group Table 



Field 










Comments 


st Group Data 


Agent 
Group 1 


Agent 
Group 2 




Agent 
Group n 


Group information 


h Assigned 










Agents belonging to this 
group 


h Prev Handle 










Previous group handle 


h Next Handle 










Next group handle 


ch Entry Used 










Entry used flag 



Table 25 




Agent Library 
Calls Queued Per Group 



Field 










Comments 


uch Group Num 


Agent 
Group 1 


Agent 
Group 2 




Agent 
Group n 


Group identifier 


St Agent Count 










Number of agents in this 
group 


us Calls Queued 










Number of calls queued in 
this group 



Table 26 



Agent Library 
Control Assignment Table 



Field 


Value 


Comments 


US Max Element 




Max element index in the table 


us Use Element 




First element in the used list 


us Free Element 




First element in the unused list 


us Use Counts 




Element count 


us Stand Alone 




Table is a standalone segment 
flag 



Table 27 



Agent Library 
Assignment Table 



Field 


Agent 
Group 
1 


Agent 
Group 
2 




Agent 
Group n 


Comments 


st Assign Data 










Assignment data field 


h Agent Prev 
Handle 










Agents previous assignment 


h Agent Next 
Handle 










Agents next assignment 


h Group Prev 
Handle 










Group's previous assignment 


h Group Next 
Handle 










Group's next assignment 


h Prev Handle 










Previous assignment handle 


h Next Handle 










Next assignment handle 


ch Entry Used 










Entry used flag 



Table 28 



73 



Agent Library 
Assignment Data Table 



Field 










Comments 


h Agent Handle 


Agent 
Handle 1 


Agent 
Handle 2 




Agent 
Handle n 


Agent table handle 


h Group Handle 










Group table handle 



Table 29 



Agent Library 
Mapping Table 



Field 










Comments 


ITid 


Agent 
Tid 1 


Agent 
Tid 2 




Agent 
Tidn 


Terminal identifier 


h Agent Handle 










Agent table handle 


ch Entry Used 










Entry used flag 



Table 30 



Agent Library 



Fast Search for Agent Table 



Field 










Comments 


ITid 


Agent 
Tid 1 


Agent 
Tid 2 




Agent 
Tidn 


Agent terminal identifier 


h Agent Handle 










Agent table handle 



Table 31 



1^ 



Agent Library 
Group Search Table 



Field 










Comments 


uchGroupNum 










Group Number 


h GroupHandle 


Group 
Handle 1 


Group 
Handle 2 




Group 
Handle n 


Group Handle 



Table 32 



Call Data Block Library 
Call Data Block Table 



Field 










Comments 


ICid 


Call ID 
1 


Call ID 
2 




Call ID n 


Call identifier 


St ANI 










Calling number 


stDN 










Called number 


St 0 Leg 


Leg! 








Originating leg 


St T Leg 


Leg 2 






Legn 


Terminating leg 


St TP 










Time points 



Table 33 
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Call Data Block Library 
Leg Data Table 



Field 


Legl 


Leg 2 


.... 


Leg n 


Comments 


St Port 










Switch port associated with 
leg. 


us State Machine 
Id 










State machine identifier. 


us State 










State of leg. 


us Event 










Event occurring on leg. 


us Conf Port 










Conference port. 



Table 34 



Call Data Block Library 
Port Table 



Field 










Comments 


s Span ID 










Span identifier 


s Channel ID 


Channel 
1 


Channel 
2 




Channel 
n 


Channel identifier 



Table 35 





Call Data Block Library 
Time Points 



5 



Field 


Call 
ID 1 


Call 
ID 2 


.... 


Call 
IDn 


Comments 


ulTPl 










Time point I which is the time the switch controller 
detects an incoming call. 


ul TP4 










Time point 4 which is the time a call is offered to an 
agent position. 


uITP5 










Time point 5 which is the time the agent port is done 
with a call. 


U1TP6 










Time point 6 which is the time at which the switch 
controller detects answer supervision from the 
terminating end. 


ulTP7 










Time point 7 which is the time at which controller detects 
reorigination DTMF sequence, originator disconnect, 
CSH timer expiration indicating terminator disconnect, or 
call park timer expiration(whichcver occurs first). At 
time point 7, the switch controller may send time points 
to the billing system. 



Table 36 
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Service Logic Program Library 
Service Logic Program Table 



5 



F leiu 










Comments 












Call identifier 


1 TiH 
1 1 IQ 










Agent terminal identifier 


s reaiure 










Feature of the call 


s rcaiure otaie 










State of the feature 


o i^cg rcaiurc 










Feature of the leg 












Expected event 


1 IvClalC V^lU 1 










Related Call ID 1 


I iVCialC \^1C1 










Related Call ID 2 


1 JvCMie l^IQ J 










Related Call ID 3 


1 Relate Cid 4 










Keiaiea L^aii lu 4 


I Relate Cid 5 










Related Call ID 5 


1 Relate Cid 6 










Related Call ID 6 


1 Relate Cid 7 










Related Call ID 7 


1 Relate Cid 8 










Related Call ID 8 


1 Relate Cid 9 










Related Call ID 9 



Table 37 
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Switch Library 
Node Information Table 



Field 










Comments 


us Node ID 


Node 1 


Node 2 




Nodes 


Logical node identifier for the switch. 


IPhysical ID 










Node serial number. 


US Host Node ID 










Host node logical identifier 


S SWType 










Switch system type (LNX, CSN) 


US MaxSlot 










Maximum number of slots. 


sStatus 










Status of the node. 



Table 38 



Switch Library 



Field 










Comments 


usSlotNo 










Stat number 


eCard Type 










card type 


Sserial Number 


Card 

Serial No. 1 


Card 

Serial No. 2 




Card 

Serial No. 3 


card serial number 


eCardStatus 










status of the card 


sConfigTag 










configure tag if any 


sCardRole 










primary, secondary etc. 


usMatchSIot 










matching front or rear slot 



Table 39 
Switch Controller 



Field 


Slotl 


Slot 2 




Slotn 


Comments 


stCardlnfo 










generic card info 


pvCard 










specific card info 


ulCardEntrySize 










card entry size 


chEntryUsed 










entry used flag 



Table 40 



C 



1 



Switch Library 
Node Table Type 



Field 


Node 1 


Node 2 




Node 3 


Comments 


stNodeData 










node data 


stSlotMap 










slot map 


stLineCard 










line cards 


stMFDSPCard 










MFDSP cards 


stCPUCard 










CPU cards 


stSS7Card 










SS7 cards 


stISDNCard 










ISDN cards 


stEXNETCard 










EXNET cards 


stOtherCard 










other types of card 


chEntryUsed 










entry used flag 



Table 41 



Switch Library 
Span Map Table 



Field 










Comments 


usLogSpanID 


Span ID 1 


Span ID 2 




Span ID 3 


logical span ID 


chEntryUsed 










entry used flag 



Table 42 

Switch Library 
Line Card Table 



Field 


Line Card 1 


Line Card 2 




Line Card n 


Comments 


stCardlnfo 










generic card info 


usMaxSpan 










# of spans (4, 8) 


usMaxChannel 










# of channels on each span 


stSpanMap 










physical to logical map 


chEntryUsed 










entry used flag 



Table 43 



f 



Switch Library 
CPU Card Table 



Field 










Comments 


stCardlnfo 










generic card info 


chlPAddr 










Internet protocol address 


sConnectState 










Connect state 


ISocketlD 










Socket identifier 


chEntryUsed 










entry used flag 



Table 44 



Switch Library 



DSP Table 



Field 


DSPl 


DSP2 




DSPn 


Comments 


ePuncType 












function type of the DSP 


sStatus 










status of this DSP 


usMaxResource 










max resources of this type 


usCurrUsed 










current used resource 


chEntryUsed 










entry used flag 



Table 45 



Switch Library 
Simm Table 



Field 










Comments 


US Simm ID 


Simm ID 
1 


Simm ID 
2 




Simm ID 
3 


Single inline memory 
module (SIMM) identifier 


eSimmType 










SIMM type 


sStatus 










status of this SIMM 


usNoDSP 










# of DSPs on this SIMM 


stDSP 










DSP structure 


ChEntryUsed 










entry used flag 



Table 46 



Switch Library 
MSDSP Card Table 



Field 


Card 1 


Card 2 




Card n 


Comments 


stCardlnfo 










generic card info 


usNoSimm 










# of simms on the card 


stSimm 










simm card structure 


chEntryUsed 










entry used flag 



Table 47 



Switch Library 



Stack Table 



Field 










Comments . 


usStacic ID 


Stack ID 1 


Stack ID2 




Stack ID3 


stack identifier 


ulOPC 










OPC 


S S 7Mod VarEnum 
eMTPVariant 










Message transfer part 


SS7ModVarEnum 
elSUPVariant 










Integrated Service Digital 
Network (ISDN) User 
Part (ISUP) 


S S7Mod VarEnum 
eLSPVariant 










eL3P 


chEntryUsed 










entry used flag 



Table 48 



4 i . 
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Switch Library 
Linkset Table 



Field 










Comments 


usLinkset ID 


Linkset ID 1 


Linkset ID 2 




Linkset ID n 


Linkset identifier which 
should be one byte 


ulAPC 










adjacent point code 


usStackID 










stack identifier 


chEntryUsed 










entry used flag 



Table 49 
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Switch Library 
Link Table 



Field 










Comments 


us LinkID 


Link ID 1 


Link ID 2 




Link ID n 


Link identifier 


usStackID 










Stack identifier 


usLinkset ID 










Linkset identifier 


usSLC 










one byte (OxOO-OxOF) Signaling Link Code 


usDataRate 










one byte (0x00-64 Kbps, 0x01-56 Kbps) 


usSpanID 










span ID (two bytes) 


usChannellD 










channel (one byte) 


chEntryUsed 










entry used flag 



Table 50 
Switch Library 



Field 










Comments 


usDestID 


Dest ID 1 


Dest ID 2 




Dest ID 3 


destination identifier 


ulDPC 










destination point code 


chEntryUsed 










entry used flag 



Table 51 




Switch Library 
Route Table 



Field 










Comments 


US Route ID 


Route ID 
1 


Route ID 
2 




Route ID 
n 


Route identifier 


usStackID 










Stack identifier which is 
one byte one byte 


ulDPC 










destination point code 


usLinksetID 










Linkset identifier 


usDestID 










destination identifier 


sPriority 










priority of the route (byte) 


chEntryUsed 










entry used flag 



Table 52 



Field 



Switch Library 
SS7 Card Table 



SS7 
Card 1 



SS7 
Card 2 



SS7 
Card n 



Comments 



stCardlnfo 
stStack 



stLinkset 



stLink 



generic card info 



stack type 



linkset type 



link type 



stDest 
stRoute 



destination type 



route type 



chEntryUsed 



entry used flag 



Table 53 
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Switch Library 



Field 


EXNET 
Card 2 


EXNET 
Card 2 




EXNET 
Card n 


Comments 


stCard Info 










Generic card information 


usRing ID 










Logic ring identifier 


chEntry Used 










entry used flag 



Table 54 




Switch Library 



Field 










Comments 


usFacSpan ID 


Facility 
Span ID I 


Facility 
Span ID 2 




Facility 
Span ID n 


facility span identifier 


chEntryUsed 










entry used flag 



Table 55 
Switch Library 



Channe 


Table 


Field 










Comments 


usSpanID 










span identifier 


usChannellD 


Channel ID 1 


Channel ID 2 




Channel ID n 


channel identifier 


sFeature 










FAS or NFAS 


sRole 










primary, or secondary, 
independent 


usRelatedChannel 










related channel 


chEntryUsed 










entry used flag 



Table 56 



Field 



stCardlnfo 



usNoDChannel 



stDChannel 



chEntryUsed 



ISDN 
Card 1 



Switch Library 
ISDN Card Table 



ISDN 
Card 2 



ISDN 
Card n 



Table 57 



Comments 



generic card info 



number of D channels 



D channel type 



entry used flag 



Switch Library 



Field 










Comments 


StCardlnfo 










generic card info 


chEntryUsed 










entry used flag 



u 
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Switch Library 
Card Union Table 



Field 










Comments 


stCPUCard 










CPU card 


stLineCard 










Line Card 


stMFDSPCard 










MFDSP Card 


stSS7Card 










SS7 Card 


stISDNCard 










ISDN Card 


stOtherCard 










Other Card 


stEXNETCard 










EXNET Card 



Table 59 
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